Express Mail Label No. EL543499318US 



12 UTILITY PATENT APPLICATION TRANSMITTAL 
(Large Entity) 

(Only for new nonprovisional applications under 37 CFR 1.53(b)) 



Docket No. 
2204/A42 



Total Pages in this Submission 
75 



= v III 1 1 II (f^MHT^^' ^M'SSIONER FOR PATENTS o 

^= o Box Patent Application a, i 

Washington, D.C. 20231 1 

Transmitted herewith for filing under 35 U.S.C. 1 11 (a) and 37 C.F.R. 1 .53(b) is a new utility patent application for ag\j> i 
invention entitled: oi\i 



SYSTEM, DEVICE, AND METHOD FOR BRIDGING NETWORK TRAFFIC 



I- 



and invented by: 



YUNZHOU LI 



If a CONTINUATION APPLICATION, check appropriate box and supply the requisite information: 

□ Continuation □ Divisional □ Continuation-in-part (CIP) of prior application No.: 
Which is a: 

□ Continuation □ Divisional □ Continuation-in-part (CIP) of prior application No.: 
Which is a: 

□ Continuation □ Divisional □ Continuation-in-part (CIP) of prior application No.: 
Enclosed are: 

Application Elements 

1 . □ Filing fee as calculated and transmitted as described below 

2. IS Specification having 41 pages and including the following: 

a. ^ Descriptive Title of the Invention 

b. 13 Cross References to Related Applications (/fapp//cat>/ej 

c. □ Statement Regarding Federally-sponsored Research/Development (if applicable) 

d. □ Reference to Microfiche Appendix (if applicable) 

e. IS Background of the Invention 

f. S Brief Summary of the Invention 

g. M Brief Description of the Drawings (if drawings filed) 

h. IS Detailed Description 

i. IS Claim(s) as Classified Below 
j. IS Abstract of the Disclosure 



Page 1 of 3 



P01ULRG/REV04 



UTILITY PATENT APPLICATION TRANSMITTAL 
(Large Entity) 



Docket No. 
2204/A42 



(Only for new nonprovisional applications under 37 CFR 1.53(b)) 



Total Pages in this Submission 
75 



3. m 



Application Elements (Continued) 

Drawing(s) (when necessary as prescribed by 35 USC 1 13) 



a. 



□ Formal 



Number of Sheets 



b. 



[3 Informal 



Number of Sheets 



27 



4. S Oath or Declaration 

a. □ Ue\N\y executed (original or copy) 13 Unexecuted 

b. □ Copy from a prior application (37 CFR 1 .63(d)) (for continuation/divisional application only) 

c. 13 With Power of Attorney □ Without Power of Attorney 

d. □ DELETION OF INVENTORfS) 

Signed statement attached deleting inventor(s) named in the prior application, 
see 37 C.F.R. 1 .63(d)(2) and 1 .33(b). 

5. □ Incorporation By Reference (usable if Box 4b is checked) 

The entire disclosure of the prior application, from which a copy of the oath or declaration is supplied under 
Box 4b, is considered as being part of the disclosure of the accompanying application and is hereby 
incorporated by reference therein. 

6. □ Computer Program in Microfiche (Appendix) 

7. □ Nucleotide and/or Amino Acid Sequence Submission (if applicable, all must be included) 

a. □ Paper Copy 

b. □ Computer Readable Copy (identical to computer copy) 

c. □ Statement Verifying Identical Paper and Computer Readable Copy 



8. □ Assignment Papers (cover sheet & document(s)) 

9. □ 37 CFR 3.73(B) Statement (when there is an assignee) 

10. □ English Translation Document (/fapp/Zcab/ej 

11. □ Information Disclosure Statement/PTO-1 449 □ Copies of IDS Citations 

12. □ Preliminary Amendment 

1 3. 3 Acknowledgment postcard 

14. S Certificate of Mailing 

□ First Class 13 Express Mail fSpec/^ La/?e/ /Vo.;.- EL543499318US 



Accompanying Application Parts 



Page 2 of 3 



P01ULRG/REV04 



UTILITY PATENT APPLICATION TRANSMITTAL 
(Large Entity) 

(Only for new nonprovisional applications under 37 CFR 1.53(b)) 



Docket No. 
2204/A42 



Total Pages in this Submission 
75 



Accompanying Application Parts (Continued) 

1 5. □ Certified Copy of Priority Document(s) (if foreign priority is claimed) 



16. □ Additional Enclosures fp/ease/afenf/'/ybe/oM/j; 



Fee Calculation and Transmittal 



CLAIMS AS FILED 



For 


#Filed 


#Allowed 


#Extra 




Rate 


Fee 


Total Claims 


57 


-20 = 


37 




$18.00 


$666.00 


Indep. Claims 


9 


- 3 = 


6 




$78.00 


$468.00 



Multiple Dependent Claims (check if applicable) □ 



$690.00 



OTHER FEE (specify purpose) 



TOTAL FILING FEE 



□ A clieck in the amount of to cover the filing fee is enclosed. 

□ The Commissioner is hereby authorized to charge and credit Deposit Account No. 
as described below. A duplicate copy of this sheet is enclosed. 

□ Charge the amount of as filing fee. 

□ Credit any overpayment. 

□ Charge any additional filing fees required under 37 C.F.R. 1.16and 1.17. 

□ Charge the issue fee set in 37 C.F.R. 1 .18 at the mailing of the Notice of Allowance, 
pursuantto 37 C.F.R. 1.311(b). ^ 



Dated: September 22, 2000 



iiliii 
2101 

PATENT TRODEHflRK OFFICE 



T\ \M~ — 



Signature 
Jeffrey T. Klayman 
Registration No. 39,250 
BROMBERG & SUNSTEIN LLP 
125 Summer Street 
Boston, MA 02110-1618 

Tel: 617-443-9292 



Page 3 of 3 



P01ULRG/REV04 



CERTIFICATE OF MAILING BY "EXPRESS MAIL" (37 CFR 1.10) 

Applicant(s): YUNZHOU LI 



Docket No. 
2204/A42 



Serial No. 
NOT YET ASSIGNED 



Filing Date 
HEREWITH 



Examiner 
NOT YET ASSIGNED 



Group Art Unit 
NOT YET ASSIGNED 



Invention : SYSTEM, DEVICE, AND METHOD FOR BRIDGING NETWORK TRAFFIC 



I hereby certify that this New utility patent application and related papers thereto 



(Identify type of correspondence) 

is being deposited with the United States Postal Service "Express Mail Post Office to Addressee" service under 
37 CFR 1.10 in an envelope addressed to: The Commissioner of Patents , Washington, D.C. 

20231-0001 on September 22, 2000 

(Date) 

Jeffrey T. Klayman 



(Typed or Printed Name of Person Mailing Correspondence ) 
a \ Signature '6f Person Mailing Correspondence ) 



EL543499318US 

("Express Mail" Mailing Label Number) 



Note: Each paper must have its own certificate of mailing. 



Copyright 1995 Legalsoft 



P06B/REV02 



IN THE UNITED STATES PATENT AND TRADEMARK OFHCE 



APPLICATION FOR UNITED STATES PATENT 



FOR 



SYSTEM, DEVICE, AND METHOD FOR BRIDGING NETWORK TRAFFIC 



Inventors: 



Yunzhou Li 

351 Pawtucket Boulevard Unit 7 
Lowell, MA 01854 



Attorney Docket No.: 2204/ A42 
Client Reference No.: BA0491 



Attorneys: 

BROMBERG & SUNSTEIN LLP 
125 Summer Street 
Boston, MA 021 10 
(617) 443-9292 



2204- A42- 118775 (BA0491) 
September 22, 2000 



SYSTEM, DEVICE, AND METHOD FOR BRIDGING NETWORK TRAFFIC 

CROSS-REFERENCE TO RELATED APPLICATIONS 

The present patent application may be related to the following commonly owned 
United States patent applications, which are hereby incorporated herein by reference in 
their entireties: 

United States Patent Application No. 09/648,273 entitled A MECHANISM FOR 
AUTOMATIC PROTECTION SWITCHING IN A ROUTER , which was filed on August 
25, 2000 in the names of Dan Adamski, David Benson, Bilel Jamoussi, Yunzhou Li, and 
Jagannath Shantigram (Attorney Docket No. 2204/A17); and 

United States Patent Application No. XX/XXX,XXX entitled APPARATUS AND 
METHOD FOR SUPPORTING MULTIPLE REDUNDANCY MECHANISMS , which 
was filed on even date herewith in the name of Yunzhou Li (Attorney Docket No. 
2204/A41). 



FIELD OF THE INVENTION 

The present invention relates generally to communication systems, and more 
particularly to bridging network traffic in a communication system. 



BACKGROUND OF THE INVENTION 

In today's information age, computers and computer peripherals are frequently 
interconnected over a communication network. A typical communication network 
includes a number of networking devices, such as switches and routers. These networking 
devices work together to route packets of information from a source device to one or more 
destination devices. 

A typical networking device includes a number of line cards. Each line card 
occupies a "slot" of the networking device, and supports one or more network interfaces 
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(each referred to hereinafter as a "slot port") through which the networking device 
communicates with various other devices, including other networking devices. Exemplary 
slot port types include Ethernet and SONET. 

Within the networking device, the line cards are interconnected by a switching 
fabric. Each line card includes one or more fabric interfaces (each referred to hereinafter 
as a "fabric port"). Among other things, the fabric ports on a particular line card may be 
used for supporting different types of fabric services (e.g., unicast versus multicast fabric 
ports) and/or for supporting priority queues (e.g., high priority versus low priority fabric 
ports). The switching fabric routes information between the line cards, and more 
particularly between fabric ports. 

Each line card includes logic for receiving, processing, and transmitting packets. 
Each line card can receive and transmit packets over its fabric port(s) and over its slot 
port(s). Each line card maintains a routing table that is typically distributed to all line 
cards by a central controller. The routing table includes a number of routing table entries, 
where each routing table entry indicates, among other things, the outgoing interface(s) 
associated with a particular destination. An outgoing interface can be a slot port on the 
same line card as indicated by a slot port number, a different line card as indicated by a 
slot number, or a specific fabric port on a different line card as indicated by a slot 
number/fabric port number pair. 

The line cards interoperate over the switching fabric in order to route packets. 
Specifically, a packet received by a particular line card (referred to hereinafter as the 
"incoming line card") over a particular slot port may be forwarded to other slot ports on 
the same line card and/or to other line cards. The incoming line card uses its routing table 
to determine the outgoing interfaces for the packet, typically based upon a destination 
address or label in the packet, and forwards the packet over the outgoing interface(s). 

In certain applications, two line cards are "bridged" so that all packets sent to a first 
line card (referred to hereinafter as a "working line card" or "WLC") over the switching 
fabric are also sent to a second line card (referred to hereinafter as the "protection line 
card" or "PLC"). Among other things, a bridge may be used for redundancy or protection 
switching. In a typical embodiment, bridging is accomplished by modifying the routing 
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table to include the PLC as an outgoing interface in all routing table entries having the 
WLC as an outgoing interface. For convenience, each such routing table entry is referred 
to hereinafter as a "bridged routing table entry." With a bridge in place, any packet that is 
sent to the WLC is also sent to the PLC. 

When used for redundancy, both the WLC and the PLC typically have active 
connections to a common destination, and the bridge forwards packets to both the WLC 
and the PLC so that the packets are sent over both connections to the common destination. 
The destination receives the same packets over both connections, and therefore the 
destination can obtain packets from either connection. In this application, the bridge is 
considered to be a permanent bridge in that the bridge must be maintained at all times in 
order for redundancy to be maintained. 

When used for protection switching, the PLC is typically a backup line card that is 
activated when communication over the WLC fails, either from a connection failure or a 
failure of the WLC itself. In this application, the bridge may be a permanent bridge or a 
temporary bridge. A permanent bridge is typically established before detecting the failure 
so that packets are already being sent to the PLC when the failure is detected. In this case, 
protection switching can be completed by simply activating the PLC upon detecting the 
failure. A temporary bridge is typically established dynamically after detecting the failure 
so that packets are not sent to the PLC until after the failure is detected. In this case, 
protection switching requires both establishment of the bridge and activation of the PLC. 

A temporary bridge may be used for applications in which a permanent bridge is 
either undesirable or impractical. For example, a temporary bridge may be required when 
the PLC is used as a backup for multiple WLCs. In this application, when a failure is 
detected with one of the WLCs, a temporary bridge is established between that WLC and 
the PLC if there is no permanent bridge established between that WLC and the PLC. 

Establishing a temporary bridge typically involves reworking the routing table in 
order to add the PLC as an outgoing interface in all routing table entries having the WLC 
as an outgoing interface. This takes a substantial amount of time during which no data 
flows over either the WLC or the PLC, especially in the case of multicast. 
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SUMMARY OF THE INVENTION 

In accordance with one aspect of the invention, a pre-computed bridged routing 
table is used to quickly bridge a first communication interface and a second 
communication interface. The pre-computed bridged routing table includes the second 
communication interface as an outgoing interface in each routing table entry having the 
first communication interface as an outgoing interface. The bridged routing table is pre- 
computed for the pair of communication interfaces by searching a main routing table for 
all main routing table entries having the first communication interface as an outgoing 
interface and creating, for each such main routing table entry, a corresponding bridged 
routing table entry including all outgoing interfaces from the main routing table entry and 
additionally including the second (bridged) communication interface as an outgoing 
interface. Bridged routing tables may be pre-computed for multiple potential 
communication interface pairs. 



BRIEF DESCRIPTION OF THE DRAWINGS 

The foregoing and other objects and advantages of the invention will be 
appreciated more fully from the following further description thereof with reference to the 
accompanying drawings wherein: 

FIG. 1 is a block diagram showing the relevant components of an exemplary 
networking device in accordance with an embodiment of the present invention; 

FIG. 2 is a block diagram that demonstrates the relationship between the line cards 
and the switching fabric of an exemplary networking device in accordance with an 
embodiment of the present invention; 

FIG. 3 is a block diagram showing the relevant components of an exemplary line 
card in accordance with an embodiment of the present invention; 

FIG. 4A shows an exemplary main routing table in accordance with an 
embodiment of the present invention; 
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FTG. 4B shows an exemplary main routing vector in accordance with an 
embodiment of the present invention; 

FIG. 5 A shows £in exemplary bridged routing table for a [Slotl,Slot2] pair in 
accordance with an embodiment of the present invention; 
5 FIG. 5B shows an exemplary bridged routing vector for a [Slotl,Slot2] pair in 

accordance with an embodiment of the present invention; 

FIG. 6 A shows an exemplary bridged routing table for a [Slot5,Slot6] pair in 
accordance with an embodiment of the present invention; 

FIG. 6B shows an exemplary bridged routing vector for a [Slot5,Slot6] pair in 
10 accordance with an embodiment of the present invention; 

FIG. 7 A shows an exemplary bridged routing table for a [Slot7,Slot8] pair in 
accordance with an embodiment of the present invention; 

FIG. 7B shows an exemplary bridged routing vector for a [Slot7,Slot8] pair in 
accordance with an embodiment of the present invention; 
15 FIG. 8A shows an exemplary bridged routing table for a [Slot9,SlotA] pair in 

accordance with an embodiment of the present invention; 

FIG. 8B shows an exemplary bridged routing vector for a [Slot9,SIotA] pair in 
accordance with an embodiment of the present invention; 

FIG. 9A shows an exemplary bridged routing table for a [Slotl,SlotE] pair in 
20 accordance with an embodiment of the present invention; 

FIG. 9B shows an exemplary bridged routing vector for a [Slotl,SlotE] pair in 
accordance with an embodiment of the present invention; 

FIG. lOA shows an exemplary bridged routing table for a [Slot5,SlotE] pair in 
accordance with an embodiment of the present invention; 
25 FIG. lOB shows an exemplary bridged routing vector for a [Slot5,SlotE] pair in 

accordance with an embodiment of the present invention; 

FIG. 1 1 A shows an exemplary bridged routing table for a [Slot7,SlotE] pair in 
accordance with an embodiment of the present invention; 

FIG.llB shows an exemplary bridged routing vector for a [Slot7,SlofE] pair in 
30 accordance with an embodiment of the present invention; 
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HG. 12 A shows an exemplary bridged routing table for a [Slot9,SlotE] pair in 
accordance with an embodiment of the present invention; 

FIG. 12B shows an exemplary bridged routing vector for a [Slot9,SlotE] pair in 
accordance with an embodiment of the present invention; 
5 FIG. 13 is a system diagram showing a networking device in communication with 

various external devices in accordance with an embodiment of the present invention; 

FIG. 14 is a system diagram showing a networking device in communication with 
various external devices using bridges in accordance with an embodiment of the present 
invention in which each working line card is protected by a different protection line card; 
10 FIG. 15 is a system diagram showing a networking device in communication with 

various external devices using a bridge in accordance with an embodiment of the present 
invention in which a single protection line card is used to protect multiple working line 
cards; 

FIG. 16 is a logic flow diagram showing exemplary logic for quickly bridging a 
15 pair of line cards in accordance with an embodiment of the present invention; 

FIG. 17 is a logic flow diagram showing exemplary logic for pre-computing a 
bridged routing table for a predetermined pair of line cards in accordance with an 
embodiment of the present invention; and 

FIG. 18 is a logic flow diagram showing exemplary protection switching logic that 
20 uses a pre-computed bridged routing table in accordance with an embodiment of the 

present invention. 



DETAILED DESCRIPTION OF A PREFERRED EMBODIMENT 

25 

In an embodiment of the present invention, bridged routing table entries are pre- 
computed (i.e., before a failure is detected) for each of a number of potential WLC/PLC 
pairs. Specifically, for each potential WLC/PLC pair, a corresponding bridged routing 
table entry including the PLC as an outgoing interface is created for each routing table 
30 entry having the WLC as an outgoing interface. For convenience, the pre-computed 
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bridged routing table entries associated with a particular WLC/PLC pair is referred to 
hereinafter as a "bridged routing table." 

The bridged routing tables are typically distributed to all line cards before a failure 
is detected. Each line card typically stores the bridged routing tables locally in a memory 
for subsequent use performing protection switching. The line cards do not update their 
respective routing tables based upon the bridged routing tables until a failure is detected. 

When a failure is detected for a particular WLC, the bridged routing table 
associated with the appropriate WLC/PLC pair is retrieved from the memory and is used to 
establish a temporary bridge between the WLC and the PLC. Specifically, each line card 
updates its routing table based upon the pre-computed routing table entries so that its 
routing table includes the PLC as an outgoing interface in all routing table entries having 
the corresponding WLC as an outgoing interface. 

By pre-computing the bridged routing table entries for the bridged WLC/PLC pair, 
the bridged routing table entries do not have to be computed at the time the temporary 
bridge is being established. Therefore, the temporary bridge can be established quickly 
following detection of the failure. 

FIG. 1 shows the relevant components of an exemplary networking device 100. 
Among other things, the networking device 100 includes at least one central controller 
120, a number of line cards 130j-130i>j, and a number of physical cards 140j-140f^. The 
central controller 120 provides management and control for the networking device 100 as 
a whole. A typical embodiment of the networking device 100 includes two redundant 
central controllers. The central controller 120 and the line cards 130,-130]^ are 
interconnected via a backplane 1 10. The backplane 1 10 includes, among other things, a 
switching fabric for high-speed communication between the line cards 130,-130j,^, a fast 
bus for downloading routing tables from the central controller 120 to the line cards 130^- 
130n, and a slow bus for management of the line cards 130i-130n by the central controller 
120. The line cards 1301-130N are inserted into physical slots of the networking device 
100. Each physical slot is associated with a slot of the switching fabric (referred to 
hereinafter as a "fabric slot"). Thus, each line card 130i-130n is coupled to a 
corresponding fabric slot. 
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Each line card 130j-130fj is coupled to a respective physical card 1401-140^. For 
convenience, the combination of a line card 130 and a physical card 140 is sometimes 
referred to as a "circuit pack group." The line cards I30]-130n provide various networking 
services for communicating with various external devices. Exemplary line card tj^pes 
include Internet Protocol (IP) and Asynchronous Transfer Mode (ATM). The physical 
cards 140[-140i^ provide physical interfaces for communicating with various external 
devices. Exemplary physical card types include Ethernet and SONET. Exemplary circuit 
pack groups include ATM-over-SONET and DP-over-SONET. 

FIG. 2 shows the line cards 130i-130n coupled to the switching fabric of the 
backplane 110. Each line card 130i-130n is associated with a corresponding fabric slot, 
and interfaces with the switching fabric through a number of fabric ports. Each line card 
130,-130n also includes a number of slot ports. In the example shown in FIG. 2, each line 
card 130,-130n is coupled to its corresponding fabric slot via two fabric ports (fabric port 1 
and fabric port 2), and each line card 130j-130i>j includes four slot ports (slot port 1, slot 
port 2, slot port 3, and slot port 4. It should be noted that each line card 130,-130^ may be 
coupled to the switching fabric via one or more fabric ports, and may have one or more 
slot ports. 

Within the networking device 100, the switching fabric routes information between 
the various line cards. Specifically, the switching fabric is capable of routing a packet 
from an incoming line card to one or more destination line cards based upon a header that 
is added to the packet by the incoming line card. The header identifies one or more 
destination slots for the packet. The header may also indicate the destination fabric port 
for each destination slot and the destination slot port(s) for each destination slot. 

Each line card 130,-130jj includes logic for receiving, processing, and transmitting 
packets. Each line card can receive and transmit packets over its fabric port(s) and over its 
slot port(s). Each line card maintains a routing table that is typically distributed to the line 
cards 130i-130fj by the central controller 120. The routing table includes a number of 
routing table entries, where each routing table entry indicates, among other things, the 
outgoing interface(s) associated with a particular destination. An outgoing interface can 
be a slot port on the same line card as indicated by a slot port number, a different line card 
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as indicated by a slot number, or a specific fabric port on a different line card as indicated 
by a slot number/fabric port number pair. 

FIG. 3 shows the relevant components of an exemplary line card 130. Among 
other things, the line card 130 includes a core processor 310, at least one routing switch 
processor (RSP) 320 for processing packets, an RSP memory 330 for storing the routing 
table, fabric port(s) 340, and slot port(s) 350. The RSP 320 is an Application Specific 
Integrated Circuit (ASIC) that is essentially a fast-forwarding engine including, among 
other things, inbound filtering logic, outbound filtering logic, policy filtering logic. 
Committed Information Rate (CIR) logic, and Type of Service (TOS) logic. The RSP 
memory 330 is used to store the routing table. The core processor 310 provides 
management and control for the line card 130, and includes logic for receiving the routing 
table from the central controller 120 over the fast bus, storing the routing table in the RSP 
memory 330, and configuring the RSP 320 based upon predetermined configuration 
information. It should be noted that FIG. 3 does not show all components of the line card 
130, nor does it show all connections between components. 

When a packet is received from a slot port 350, the RSP 320 uses the routing table 
in the RSP memory 330 to determine the outgoing interface(s) for the packet. Assuming 
that the packet needs to be forwarded to at least one other line card, the RSP 320 creates a 
header for the packet indicating at least the destination slot(s) for the packet, adds the 
header to the packet, and forwards the packet to the switching fabric over a fabric port 340. 

FIG. 4A shows an exemplary routing table 400 having three multicast routes. Each 
multicast route is associated with a particular (source, group) pair. Route 1 is associated 
with a (S1,G1) pair, and has, as its outgoing interfaces 410, slots 1, 5, 7, 9, B, and C. 
Route 2 is associated with a (S2,G2) pair, and has, as its outgoing interfaces 420, slots 5, 
7, and 9. Route 3 is associated with a (S3,G3) pair, and has, as its outgoing interfaces 430, 
slots 1, 5, B, and C. In the exemplary routing table 400, slot B and slot C are already 
bridged, such that slot C is included as an outgoing interface in each routing table entry 
(410, 430) that includes slot B as an outgoing interface. The routing table 400 is referred 
to hereinafter as the "main" routing table in order to distinguish it from bridged routing 
tables established in various embodiments of the invention. 
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A routing vector is typically maintained for each route in the main routing table 
400. Each routing vector indicates the fabric slots and slot ports associated with its 
corresponding route. The routing vectors are used by the line cards 130j-130^ to create 
headers for sending packets over the switching fabric. 

FIG. 4B shows an exemplary routing vector 440 for Route 1 in the main routing 
table 400. The routing vector 440 indicates the fabric slots associated with Route 1 in the 
main routing table 400, and also indicates the slot port(s) for each fabric slot. Specifically, 
the routing vector 440 indicates slot ports 3 and 4 for fabric slot 1, slot port 4 for fabric 
slot 5, slot port 1 for fabric slot 7, slot ports 1 and 2 for fabric slot 9, slot port 2 for fabric 
slot B, and slot port 2 for fabric slot C. The routing vector 440 is referred to hereinafter as 
the "main" routing vector for Route 1 in the main routing table 400 in order to distinguish 
it from bridged routing vectors established in various embodiments of the present 
invention described below. It should be noted that a similar routing vector would be 
established for Route 2 and Route 3 in the main routing table 400. 

In an embodiment of the present invention, a bridged routing table is pre-computed 
for each of a number of potential WLC/PLC pairs. In order to create a bridged routing 
table for a particular WLC/PLC pair, the main routing table 400 is traversed, and each 
routing table entry having the WLC as an outgoing interface is copied into the bridged 
routing table and the PLC is added as an outgoing interface. A reference is maintained to 
the corresponding routing table entry in the main routing table 400. A corresponding 
bridged routing vector identifying the slot ports for the PLC (corresponding to the slots 
ports for the WLC) is also created. The bridged routing tables and bridged routing vectors 
are not stored in the RSP memories until a bridge is established, but are instead stored in a 
general purpose memory accessible to the central controller 120 and/or the line cards 130,- 
130^. 

Various aspects of the present invention can be demonstrated by example. 

In a first example, each WLC is protected by a different PLC. Specifically, slot 2 
is used as a backup for slot 1, slot 6 is used as a backup for slot 5, slot 8 is used as a 
backup for slot 7, and slot A is used as a backup for slot 9. As in the prior example, slots 
B and C aie already bridged, with slot C acting as a backup for slot B. Thus, bridged 
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routing tables are pre-computed for the [Slotl,Slot2] pair, the [Slot5,Slot6] pair, the 
[Slot7,Slot8] pair, and the [Slot9,SlotA] pair. A corresponding bridged routing vector is 
created for each bridged routing table. There is no need to compute a bridged routing table 
and bridged routing vector for the [SlotB,SlotC] pair, since slots B and C are already 
5 bridged. 

FIG. 5 A shows a bridged routing table 500 for the [Slotl,Slot2] pair. The bridged 
routing table 500 includes routes 1 and 3 from the main routing table 400. Route 1 has, as 
its outgoing interfaces 510, slots 1, 2, 5, 7, 9, B, and C. Route 3 has, as its outgoing 
interfaces 530, slots 1, 2, 5, B, and C. The bridged routing table 500 also includes 
10 corresponding references to the outgoing interfaces lists 410 and 430 in the main routing 

table 400. 

FIG. 5B shows a bridged routing vector 540 for Route 1 of the bridged routing 
table 500. The bridged routing vector 540 indicates slot ports 3 and 4 for fabric slot 1, slot 
ports 3 and 4 for fabric slot 2 (bridged from fabric slot 1), slot port 4 for fabric slot 5, slot 
: 15 port 1 for fabric slot 7, slot ports 1 and 2 for fabric slot 9, slot port 2 for fabric slot B, and 

slot port 2 for fabric slot C. 

FIG. 6A shows a bridged routing table 600 for the [Slot5,Slot6] pair. The bridged 
routing table 600 includes routes 1, 2, and 3 from the main routing table 400. Route 1 has, 
as its outgoing interfaces 610, slots 1, 5, 6, 7, 9, B, and C. Route 2 has, as its outgoing 
20 interfaces 620, slots 5, 6, 7, and 9. Route 3 has, as its outgoing interfaces 630, slots 1, 5, 6, 

B, and C. The bridged routing table 600 also includes corresponding references to the 
outgoing interfaces lists 410, 420, and 430 in the main routing table 400. 

FIG. 6B shows a bridged routing vector 640 for Route 1 of the bridged routing 
table 600. The bridged routing vector 640 indicates slot ports 3 and 4 for fabric slot 1, slot 
25 port 4 for fabric slot 5, slot port 4 for fabric slot 6 (bridged from fabric slot 5), slot port 1 

for fabric slot 7, slot ports 1 and 2 for fabric slot 9, slot port 2 for fabric slot B, and slot 
port 2 for fabric slot C. 

FIG. 7A shows a bridged routing table 700 for the [Slot7,Slot8] pair. The bridged 
routing table 700 includes routes 1 and 2 from the main routing table 400. Route 1 has, as 
30 its outgoing interfaces 710, slots 1, 5, 7, 8, 9, B, and C. Route 2 has, as its outgoing 
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interfaces 720, slots 5, 7, 8, and 9. The bridged routing table 700 also includes 
corresponding references to the outgoing interfaces lists 410 and 420 in the main routing 
table 400. 

FIG. 7B shows a bridged routing vector 740 for Route 1 of the bridged routing 
5 table 700. The bridged routing vector 740 indicates slot ports 3 and 4 for fabric slot 1 , slot 

port 4 for fabric slot 5, slot port 1 for fabric slot 7, slot port 1 for fabric slot 8 (bridged 
from fabric slot 7), slot ports 1 and 2 for fabric slot 9, slot port 2 for fabric slot B, and slot 
port 2 for fabric slot C. 

FIG. 8A shows a bridged routing table 800 for the [Slot9,SlotA] pair. The bridged 
10 routing table 800 includes routes 1 and 2 from the main routing table 400, Route 1 has, as 

its outgoing interfaces 810, slots 1, 5, 7, 9, A, B, and C. Route 2 has, as its outgoing 
interfaces 820, slots 5, 7, 9, and A. The bridged routing table 800 also includes 
corresponding references to the outgoing interfaces lists 410 and 420 in the main routing 
table 400. 

15 FIG. 8B shows a bridged routing vector 840 for Route 1 of the bridged routing 

table 800. The bridged routing vector 840 indicates slot ports 3 and 4 for fabric slot 1 , slot 
port 4 for fabric slot 5, slot port 1 for fabric slot 7, slot ports 1 and 2 for fabric slot 9, slot 
ports 1 and 2 for fabric slot A (bridged from fabric slot 9), slot port 2 for fabric slot B, and 
slot port 2 for fabric slot C. 

20 In a second example, a single PLC is used as a backup for multiple WLCs. 

Specifically, slot E is used as a backup for slots 1, 5, 7, and 9. As in the prior examples, 
slots B and C are already bridged, with slot C acting as a backup for slot B. Thus, bridged 
routing tables are pre-computed for the [Slotl,SlotE] pair, the [Slot5,SlotE] pair, the 
[Slot7,SlotE] pair, and the [Slot9,SlotE] pair. A corresponding bridged routing vector is 

25 created for each bridged routing table. There is no need to compute a bridged routing table 

and bridged routing vector for the [SlotB,SlotC] pair, since slots B and C are already 
bridged. 

FIG. 9A shows a bridged routing table 900 for the [Slotl,SlotE] pair. The bridged 
routing table 900 includes routes 1 and 3 from the main routing table 400. Route 1 has, as 
30 its outgoing interfaces 910, slots 1,5,7, 9, B, C, and E. Route 3 has, as its outgoing 
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interfaces 930, slots 1, 5, B, C, and E. The bridged routing table 900 also includes 
corresponding references to the outgoing interfaces lists 410 and 430 in the main routing 
table 400. 

FIG. 9B shows a bridged routing vector 940 for Route 1 of the bridged routing 
table 900. The bridged routing vector 940 indicates slot ports 3 and 4 for fabric slot 1, slot 
port 4 for fabric slot 5, slot port 1 for fabric slot 7, slot ports 1 and 2 for fabric slot 9, slot 
port 2 for fabric slot B, slot port 2 for fabric slot C, and slot ports 3 and 4 for fabric slot E 
(bridged from fabric slot 1). 

FIG. lOA shows a bridged routing table 1000 for the [Slot5,SlotE] pair. The 
bridged routing table 1000 includes routes 1, 2, and 3 from the main routing table 400. 
Route 1 has, as its outgoing interfaces 1010, slots 1, 5, 7, 9, B, C, and E. Route 2 has, as 
its outgoing interfaces 1020, slots 5, 7, 9, and E. Route 3 has, as its outgoing interfaces 
1030, slots 1, 5, B, C, and E. The bridged routing table 1000 also includes corresponding 
references to the outgoing interfaces lists 410, 420, and 430 in the main routing table 400. 

FIG. lOB shows a bridged routing vector 1040 for Route 1 of the bridged routing 
table 1000. The bridged routing vector 1040 indicates slot ports 3 and 4 for fabric slot 1, 
slot port 4 for fabric slot 5, slot port 1 for fabric slot 7, slot ports 1 and 2 for fabric slot 9, 
slot port 2 for fabric slot B, slot port 2 for fabric slot C, and slot port 4 for fabric slot E 
(bridged from fabric slot 5). 

FIG. 1 1 A shows a bridged routing table 1 100 for the [Slot7,SlotE] pair. The 
bridged routing table 1 100 includes routes 1 and 2 from the main routing table 400. Route 
1 has, as its outgoing interfaces 1110, slots 1, 5, 7, 9, B, C, and E. Route 2 has, as its 
outgoing interfaces 1120, slots 5, 7, 9, and E. The bridged routing table 1100 also includes 
corresponding references to the outgoing interfaces lists 410 and 420 in the main routing 
table 400. 

FIG. 1 IB shows a bridged routing vector 1 140 for Route 1 of the bridged routing 
table 1 100. The bridged routing vector 1 140 indicates slot ports 3 and 4 for fabric slot 1, 
slot port 4 for fabric slot 5, slot port 1 for fabric slot 7, slot ports 1 and 2 for fabric slot 9, 
slot port 2 for fabric slot B, slot port 2 for fabric slot C, and slot port 1 for fabric slot E 
(bridged from fabric slot 7). 
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FIG. 12A shows a bridged routing table 1200 for the [Slot9,SlotE] pair. The 
bridged routing table 1200 includes routes 1 and 2 from the main routing table 400. Route 
1 has, as its outgoing interfaces 1210, slots 1, 5, 7, 9, B, C, and E. Route 2 has, as its 
outgoing interfaces 1220, slots 5, 7, 9, and E. The bridged routing table 1200 also includes 
5 corresponding references to the outgoing interfaces lists 410 and 420 in the main routing 

table 400. 

FIG. 12B shows a bridged routing vector 1240 for Route 1 of the bridged routing 
table 1200. The bridged routing vector 1240 indicates slot ports 3 and 4 for fabric slot 1, 
slot port 4 for fabric slot 5, slot port 1 for fabric slot 7, slot ports 1 and 2 for fabric slot 9, 

10 slot port 2 for fabric slot B, slot port 2 for fabric slot C, and slot ports 1 and 2 for fabric 

slot E (bridged from fabric slot 9). 

FIG. 13 shows an exemplary communication system 1300 in which the networking 
device 100 is coupled to various external devices. The networking device 100 is coupled 
via slot 1 to external device 1310. The networking device 100 is coupled via slot 5 to 

15 external device 1320. The networking device 100 is coupled via slot 7 to external device 

1330. The networking device 100 is coupled via slot 9 to external device 1340. For the 
sake of simplicity, network connections involving slots B and C of the networking device 
100 are not shown. 

FIG. 14 shows an exemplary communication system 1400 in which each WLC is 
20 protected by a different PLC as in the first example described above. Because each WLC 

is protected by a different PLC, failures affecting multiple WLCs can be bypassed by 
establishing the appropriate bridges. A temporary bridge 1410 is established between slots 
1 and 2 using the bridged routing table 500 in order to bypass a failure affecting 
communication with external device 1310 over slot 1. A temporary bridge 1420 is 
25 established between slots 5 and 6 using the bridged routing table 600 in order to bypass a 

failure affecting communication with external device 1320 over slot 5. A temporary 
bridge 1430 is established between slots 7 and 8 using the bridged routing table 700 in 
order to bypass a failure affecting communication with external device 1330 over slot 7. A 
temporary bridge 1440 is established between slots 9 and A using the bridged routing table 
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800 in order to bypass a failure affecting communication with external device 1340 over 
slot 9. 

FIG. 15 shows an exemplary communication system 1500 in which a single PLC is 
used to protect multiple WLCs, as in the second example above. Because a single PLC is 
5 used to protect multiple WLCs, only one WLC can be protected at any given time. In this 

example, a failure affecting communication with external device 1340 over slot 9 is 
bypassed by establishing a temporary bridge 1510 between slots 9 and E using the bridged 
routing table 1200. As long as the temporary bridge between slots 9 and E is active, 
failures affecting communication over slots 1, 5, and 7 cannot be protected using slot E. 

10 FIG. 16 shows exemplary logic 1600 for quickly bridging a pair of line cards. 

Beginning in block 1602, the logic pre-computes bridged routing table entries for a 
predetermined pair of line cards, in block 1604. The logic typically stores the pre- 
computed bridged routing table entries, in block 1606. The logic subsequently uses the 
pre-computed bridged routing table entries to establish a bridge between the predetermined 

15 pair of line cards, in block 1608. The logic 1600 terminates in block 1699. 

FIG. 17 shows exemplary logic 1700 for pre-computing a bridged routing table for 
a particular WLC/PLC pair. Beginning in block 1702, the logic obtains a routing table 
entry from the main routing table, in block 1704, and determines whether the routing table 
entry includes the WLC as an outgoing interface, in block 1706. If the routing table entry 

20 does not include the WLC as an outgoing interface (NO in block 1708), then the logic 

proceeds to block 1716. If the routing table entry does include the WLC as an outgoing 
interface (YES in block 1708), then the logic copies the routing table entry as a bridged 
routing table entry into the bridged routing table for the WLC/PLC pair, in block 1710, 
adds the PLC as an outgoing interface of the bridged routing table entry, in block 1712, 

25 creates a bridged routing vector identifying the slot ports for the PLC (corresponding to the 

slot ports for the WLC), in block 1714, and proceeds to block 1716. In block 1716, the 
logic determines whether there are any additional routing table entries in the main routing 
table. If there are additional routing table entries in the main routing table (YES in block 
1716), then the logic recycles to block 1704 to process another routing table entry of the 
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main routing table. If there are no additional routing table entries in the main routing table 
(NO in block 1716), then the logic terminates in block 1799. 

FIG. 18 shows exemplary protection switching logic 1800 that uses a pre-computed 
bridged routing table. Beginning in block 1802, and upon detecting a failure affecting a 
5 WLC, in block 1804, the logic determines a PLC to back up the WLC, in block 1806. The 

logic then obtains a pre-computed bridged routing table for the WLC/PLC pair, in block 
1808. It should be noted that there may be multiple bridged routing tables associated with 
a particular WLC, with each bridged routing table using a different PLC. After obtaining 
the bridged routing table for the WLC/PLC pair, in block 1808, the logic establishes a 

10 bridge between the WLC and the PLC using the pre-computed bridged routing table, in 

block 1810. Establishing the bridge may involve, among other things, distributing the pre- 
computed bridged routing table to all line cards. The logic 1800 terminates in block 1899. 

It should be noted that, although various embodiments of the present invention are 
described with reference to multicast routes, the present invention is in no way limited to 

15 bridging multicast routes. The bridging mechanism described herein can be used for 

bridging of both unicast and multicast routes. 

It should be noted that terms such as "switch" and "router" are used herein to 
describe various communication devices that may be used in a communication system, and 
should not be construed to limit the present invention to any particular communication 

20 device type. Thus, a communication device may include, without limitation, a bridge, 

router, bridge-router (brouter), switch, node, or other communication device. 

It should also be noted that the term "packet" is used herein to describe a 
communication message that may be used by a communication device (e.g., created, 
transmitted, received, stored, or processed by the communication device) or conveyed by a 

25 communication medium, and should not be construed to limit the present invention to any 

particular communication message type, communication message format, or 
communication protocol. Thus, a communication message may include, without 
limitation, a frame, packet, datagram, user datagram, cell, or other type of communication 
message. 
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It should also be noted that the logic flow diagrams are used herein to demonstrate 
various aspects of the invention, and should not be construed to limit the present invention 
to any particular logic flow or logic implementation. The described logic may be 
partitioned into different logic blocks (e.g., programs, modules, functions, or subroutines) 
without changing the overall results or otherwise departing from the true scope of the 
invention. Often times, logic elements may be added, modified, omitted, performed in a 
different order, or implemented using different logic constructs (e.g., logic gates, looping 
primitives, conditional logic, and other logic constructs) without changing the overall 
results or otherwise departing from the true scope of the invention. 

The present invention may be embodied in many different forms, including, but in 
no way limited to, computer program logic for use with a processor (e.g., a 
microprocessor, microcontroller, digital signal processor, or general purpose computer), 
programmable logic for use with a programmable logic device (e.g., a Field Programmable 
Gate Array (FPGA) or other PLD), discrete components, integrated circuitry {e.g., an 
Application Specific Integrated Circuit (ASIC)), or any other means including any 
combination thereof. In a typical embodiment of the present invention, predominantly all 
of the logic for pre-computing bridged routing tables, storing the pre-computed bridged 
routing tables, and using the pre-computes bridged routing tables for protection switching 
or otherwise is implemented as a set of computer program instructions that is converted 
into a computer executable form, stored as such in a computer readable medium, and 
executed by a microprocessor within the networking device 100 under the control of an 
operating system. 

Computer program logic implementing all or part of the functionality previously 
described herein may be embodied in various forms, including, but in no way limited to, a 
source code form, a computer executable form, and various intermediate forms (e.g., forms 
generated by an assembler, compiler, linker, or locator). Source code may include a series 
of computer program instructions implemented in any of various programming languages 
(e.g., an object code, an assembly language, or a high-level language such as Fortran, C, 
C++, JAVA, or HTML) for use with various operating systems or operating environments. 
The source code may define and use various data structures and communication messages. 
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The source code may be in a computer executable form (e.g., via an interpreter), or the 
source code may be converted {e.g., via a translator, assembler, or compiler) into a 
computer executable form. 

The computer program may be fixed in any form (e.g., source code form, computer 
5 executable form, or an intermediate form) either permanently or transitorily in a tangible 

storage medium, such as a semiconductor memory device {e.g., a RAM, ROM, PROM, 
EEPROM, or Flash-Programmable RAM), a magnetic memory device {e.g., a diskette or 
fixed disk), an optical memory device {e.g., a CD-ROM), or other memory device. The 
computer program may be fixed in any form in a signal that is transmittable to a computer 

10 using any of various communication technologies, including, but in no way limited to, 

analog technologies, digital technologies, optical technologies, wireless technologies, 
networking technologies, and internetworking technologies. The computer program may 
be distributed in any form as a removable storage medium with accompanying printed or 
electronic documentation {e.g., shrink wrapped software), preloaded with a computer 

15 system {e.g., on system ROM or fixed disk), or distributed from a server or electronic 

bulletin board over the communication system {e.g., the Internet or World Wide Web). 

Hardware logic (including programmable logic for use with a programmable logic 
device) implementing all or part of the functionality previously described herein may be 
designed using traditional manual methods, or may be designed, captured, simulated, or 

20 documented electronically using various tools, such as Computer Aided Design (CAD), a 

hardware description language (e.g., VHDL or AHDL), or a PLD programming language 
(e.g., PALASM, ABEL, or CUPL). 

Programmable logic may be fixed either permanently or transitorily in a tangible 
storage medium, such as a semiconductor memory device {e.g., a RAM, ROM, PROM, 

25 EEPROM, or Flash-Progranraiable RAM), a magnetic memory device {e.g., a diskette or 

fixed disk), an optical memory device {e.g., a CD-ROM), or other memory device. The 
programmable logic may be fixed in a signal that is transmittable to a computer using any 
of various communication technologies, including, but in no way limited to, analog 
technologies, digital technologies, optical technologies, wireless technologies, networking 

30 technologies, and internetworking technologies. The programmable logic may be 
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distributed as a removable storage medium with accompanying printed or electronic 
documentation (e.g., shrink wrapped software), preloaded with a computer system (e.g., on 
system ROM or fixed disk), or distributed from a server or electronic bulletin board over 
the communication system (e.g., the Internet or World Wide Web). 

5 Thus, the present invention may be embodied as a method for bridging network 

traffic in a networking device having a plurality of communication interfaces such as line 
cards. The method involves creating a bridged routing entry for bridging a first 
communication interface and a second communication interface before requiring a bridge 
between the predetermined pair of communication interfaces, subsequently determining 

10 that a bridge is needed between the first communication interface and the second 

communication interface, and establishing the bridge between the first communication 
interface and the second communication interface using the bridged routing entry. 
Creating the bridged routing entry for bridging the first communication interface and the 
second communication interface involves adding the second conmnunication interface as 

15 an outgoing interface to a routing entry having the first communication interface as an 

outgoing interface, and may also involve creating a bridged routing vector for bridging the 
first communication interface and the second communication interface. Determining that 
the bridge is needed between the first communication interface and the second 
communication interface typically involves detecting a failure affecting communication 

20 over the first communication interface. 

The present invention may also be embodied as a method for bridging network 
traffic in a networking device having a plurality of communication interfaces such as line 
cards. The method involves creating a bridged routing table for bridging a first 
communication interface and a second communication interface before requiring a bridge 

25 between the predetermined pair of communication interfaces, subsequently determining 

that a bridge is needed between the first communication interface and the second 
communication interface, and establishing the bridge between the first communication 
interface and the second communication interface using the bridged routing table. 
Creating the bridged routing table for bridging the first communication interface and the 

30 second communication interface involves finding in a main routing table a number of main 
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routing entries having the first communication interface as an outgoing interface and 
creating in the bridged routing table a corresponding bridged routing entry for each of said 
number of main routing entries, wherein each bridged routing entry includes all outgoing 
interfaces from its corresponding main routing entry and further includes the second 
5 communication interface as an outgoing interface. Creating a corresponding bridged 

routing entry for a main routing involves copying the main routing entry as a bridged 
routing entry into the bridged routing table and adding the second communication interface 
as an outgoing interface to the bridged routing entry, and may also involve creating a 
bridged routing vector for the bridged routing entry. Creating the corresponding bridged 

10 routing entry for the main routing entry involves including in the bridged routing entry a 

reference to the main routing entry in the main routing table. Determining that the bridge 
is needed between the first communication interface and the second communication 
interface typically involves detecting a failure affecting communication over the first 
communication interface. 

15 The present invention may also be embodied as a method for protection switching 

in a networking device having a plurality of communication interfaces such as line cards. 
The method involves pre-establishing a bridged routing table for each of a number of 
communication interface pairs, where each communication interface pair represents a 
working communication interface and a corresponding protection conmiunication interface 

20 from among the plurality of communication interfaces, detecting a failure affecting 

communication over a working communication interface, determining a protection 
communication interface to protect the working communication interface, obtaining the 
pre-established bridged routing table for the communication interface pair associated with 
the working communication interface and the protection communication interface, and 

25 bridging the protection communication interface to the working communication interface 

using the pre-established bridged routing table for the communication interface pair 
associated with the working communication interface and the protection communication 
interface. Pre-establishing a bridged routing table for a communication interface pair 
involves finding in a main routing table a number of main routing entries having the 

30 working communication interface as an outgoing interface and creating in the bridged 
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routing table a corresponding bridged routing entry for each of said number of main 
routing entries, wherein each bridged routing entry includes all outgoing interfaces from its 
corresponding main routing entry and further includes the protection communication 
interface as an outgoing interface. Creating a corresponding bridged routing entry for a 
5 main routing entry involves copying the main routing entry as a bridged routing entry into 

the bridged routing table and adding the protection communication interface as an 
outgoing interface to the bridged routing entry, and may also involve creating a bridged 
routing vector for the bridged routing entry. Creating the corresponding bridged routing 
entry for the main routing entry involves including in the bridged routing entry a reference 

10 to the main routing entry in the main routing table. 

The present invention may also be embodied as an apparatus having a plurality of 
communication interfaces such as line cards, bridge pre-establishment logic operably 
coupled to create a bridged routing entry for bridging a first communication interface and a 
second interface from among the plurality of communication interfaces before a bridge is 

15 needed between the first communication interface and the second interface, and bridge 

establishment logic operably coupled to establish a bridge between the first 
communication interface and the second communication interface using the pre- 
established bridged routing entry upon determining that a bridge is needed between the 
first communication interface and the second communication interface. The bridge pre- 

20 establishment logic is operably coupled to create the bridged routing entry by adding the 

second communication interface as an outgoing interface to a routing entry having the first 
communication interface as an outgoing interface. The bridge pre-establishraent logic may 
also be operably coupled to create a bridged routing vector for bridging the first 
communication interface and the second communication interface. The bridge 

25 establishment logic is operably coupled to establish the bridge upon detecting a failure 

affecting communication over the first communication interface. 

The present invention may also be embodied as a computer program for controlling 
a computer system. The computer program includes bridge pre-establishment logic 
programmed to create a bridged routing entry for bridging a first communication interface 

30 and a second interface from among a plurality of communication interfaces before a bridge 
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is needed between the first communication interface and the second interface and bridge 
establishment logic programmed to establish a bridge between the first communication 
interface and the second communication interface using the pre-established bridged 
routing entry upon determining that a bridge is needed between the first communication 
interface and the second communication interface. The bridge pre-establishment logic is 
programmed to create the bridged routing entry by adding the second communication 
interface as an outgoing interface to a routing entry having the first communication 
interface as an outgoing interface. The bridge pre-establishment logic may also be 
programmed to create a bridged routing vector for bridging the first communication 
interface and the second communication interface. The bridge establishment logic is 
programmed to establish the bridge upon detecting a failure affecting communication over 
the first communication interface. The computer program may be embodied in a computer 
readable medium or in a data signal. 

The present invention may also be embodied as an apparatus having a plurality of 
communication interfaces such as line cards, bridge pre-establishment logic operably 
coupled to create a bridged routing table for bridging a first communication interface and a 
second interface from among a plurality of communication interfaces before a bridge is 
needed between the first communication interface and the second interface, and bridge 
establishment logic operably coupled to establish a bridge between the first 
communication interface and the second communication interface using the pre- 
established bridged routing table upon determining that a bridge is needed between the 
first communication interface and the second communication interface. The bridge pre- 
establishment logic is operably coupled to create the bridged routing table by finding in a 
main routing table a number of main routing entries having the first communication 
interface as an outgoing interface and creating in the bridged routing table a corresponding 
bridged routing entry for each of said number of main routing entries, wherein each 
bridged routing entry includes all outgoing interfaces from its corresponding main routing 
entry and further includes the second communication interface as an outgoing interface. 
The bridge pre-establishment logic is operably coupled to create a corresponding bridged 
routing entry for a main routing entry by copying the main routing entry as a bridged 
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routing entry into the bridged routing table and adding the second communication interface 
as an outgoing interface to the bridged routing entry. The bridge pre-establishment logic 
may also be operably coupled to create a bridged routing vector for the bridged routing 
entry. The bridge pre-establishment logic is operably coupled to include in the bridged 
5 routing entry a reference to the main routing entry in the main routing table. The bridge 

establishment logic is operably coupled to establish the bridge upon detecting a failure 
affecting communication over the first communication interface. 

The present invention may also be embodied as a computer program for controlling 
a computer system. The computer program includes bridge pre-establishment logic 

10 programmed to create a bridged routing table for bridging a first communication interface 

and a second interface from among a plurality of communication interfaces before a bridge 
is needed between the first communication interface and the second interface and bridge 
establishment logic programmed to establish a bridge between the first communication 
interface and the second communication interface using the pre-established bridged 

15 routing table upon determining that a bridge is needed between the first communication 

interface and the second communication interface. The bridge pre-establishment logic is 
programmed to create the bridged routing table by finding in a main routing table a 
number of main routing entries having the first communication interface as an outgoing 
interface and creating in the bridged routing table a corresponding bridged routing entry 

20 for each of said number of main routing entries, wherein each bridged routing entry 

includes all outgoing interfaces from its corresponding main routing entry and further 
includes the second communication interface as an outgoing interface. The bridge pre- 
establishment logic is programmed to create a corresponding bridged routing entry for a 
main routing entry by copying the main routing entry as a bridged routing entry into the 

25 bridged routing table and adding the second communication interface as an outgoing 

interface to the bridged routing entry. The bridge pre-establishment logic may also be 
programmed to create a bridged routing vector for the bridged routing entry. The bridge 
pre-establishment logic is programmed to include in the bridged routing entry a reference 
to the main routing entry in the main routing table. The bridge establishment logic is 

30 programmed to establish the bridge upon detecting a failure affecting communication over 
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the first communication interface. The computer program may be embodied in a computer 
readable medium or in a data signal. 

The present invention may also be embodied as an apparatus having a plurality of 
communication interfaces such as line cards, bridge pre-establishment logic operably 
5 coupled to create a bridged routing table for each of a number of communication interface 

pairs, where each communication interface pair represents a working communication 
interface and a corresponding protection communication interface from among the 
plurality of communication interfaces, and bridge establishment logic operably coupled to 
establish a bridge between a working communication interface and a corresponding 
- 10 protection communication interface using the bridged routing table associated with the 

working communication interface and corresponding protection communication interface 
upon detecting a failure affecting communication over the working communication 
interface. The bridge pre-establishment logic is operably coupled to create a bridged 
routing table for a communication interface pair by finding in a main routing table a 

15 number of main routing entries having the working communication interface as an 

outgoing interface and creating in the bridged routing table a corresponding bridged 
routing entry for each of said number of main routing entries, wherein each bridged 
routing entry includes all outgoing interfaces from its corresponding main routing entry 
and further includes the protection communication interface as an outgoing interface. The 

20 bridge pre-establishment logic is operably coupled to create a corresponding bridged 

routing entry for a main routing entry by copying the main routing entry as a bridged 
routing entry into the bridged routing table and adding the protection communication 
interface as an outgoing interface to the bridged routing entry. The bridge pre- 
establishment logic may also be operably coupled to create a bridged routing vector for the 

25 bridged routing entry. The bridge pre-establishment logic is operably coupled to include 

in the bridged routing entry a reference to the main routing entry in the main routing table. 

The present invention may also be embodied as a computer program for controlling 
a computer system. The computer program includes bridge pre-establishment logic 
programmed to create a bridged routing table for each of a number of communication 

30 interface pairs, where each communication interface pair represents a working 
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communication interface and a corresponding protection communication interface from 
among the plurality of communication interfaces and bridge establishment logic 
programmed to establish a bridge between a working communication interface and a 
corresponding protection communication interface using the bridged routing table 
associated with the working communication interface and corresponding protection 
communication interface upon detecting a failure affecting communication over the 
working communication interface. The bridge pre-establishment logic is programmed to 
create a bridged routing table for a communication interface pair by finding in a main 
routing table a number of main routing entries having the working communication 
interface as an outgoing interface and creating in the bridged routing table a corresponding 
bridged routing entry for each of said number of main routing entries, wherein each 
bridged routing entry includes all outgoing interfaces from its corresponding main routing 
entry and further includes the protection communication interface as an outgoing interface. 
The bridge pre-establishment logic is programmed to create a corresponding bridged 
routing entry for a main routing entry by copying the main routing entry as a bridged 
routing entry into the bridged routing table and adding the protection communication 
interface as an outgoing interface to the bridged routing entry. The bridge pre- 
establishment logic may also be programmed to create a bridged routing vector for the 
bridged routing entry. The bridge pre-establishment logic is programmed to include in the 
bridged routing entry a reference to the main routing entry in the main routing table. The 
computer program may be embodied in a computer readable medium or in a data signal. 

The present invention may be embodied in other specific forms without departing 
from the true scope of the invention. The described embodiments are to be considered in 
all respects only as illustrative and not restrictive. 
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I claim: 



1. A method for bridging network traffic in a networking device having a plurahty of 
communication interfaces, the method comprising: 

5 creating a bridged routing entry for bridging a first communication interface and a 

second communication interface before requiring a bridge between the predetermined pair 
of communication interfaces; 

subsequently determining that a bridge is needed between the first communication 
interface and the second communication interface; and 
10 establishing the bridge between the first communication interface and the second 

communication interface using the bridged routing entry. 

2. The method of claim 1, wherein creating the bridged routing entry for bridging the 
first communication interface and the second communication interface comprises: 

15 adding the second communication interface as an outgoing interface to a routing 

entry having the first contmiunication interface as an outgoing interface. 

3. The method of claim 2, wherein creating the bridged routing entry for the first 
communication interface and the second communication interface further comprises: 

20 creating a bridged routing vector for bridging the first communication interface and 

the second communication interface. 



4. The method of claim 1, wherein determining that the bridge is needed between the 
first communication interface and the second communication interface comprises: 
25 detecting a failure affecting communication over the first communication interface. 



5. The method of claim 1, wherein the plurality of communication interfaces 
comprises a plurality of line cards. 
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6. A method for bridging network traffic in a networking device having a plurahty of 
communication interfaces, the method comprising: 

creating a bridged routing table for bridging a first communication interface and a 
second communication interface before requiring a bridge between the predetermined pair 
of communication interfaces; 

subsequently determining that a bridge is needed between the first communication 
interface and the second communication interface; and 

establishing the bridge between the first conmiunication interface and the second 
communication interface using the bridged routing table. 

7. The method of claim 6, wherein creating the bridged routing table for bridging the 
first communication interface and the second communication interface comprises: 

finding in a main routing table a number of main routing entries having the first 
communication interface as an outgoing interface; and 

creating in the bridged routing table a corresponding bridged routing entry for each 
of said number of main routing entries, wherein each bridged routing entry includes all 
outgoing interfaces from its corresponding main routing entry and further includes the 
second communication interface as an outgoing interface. 

8. The method of claim 7, wherein creating a corresponding bridged routing entry for 
a main routing entry comprises: 

copying the main routing entry as a bridged routing entry into the bridged routing 
table; and 

adding the second communication interface as an outgoing interface to the bridged 
routing entry. 

9. The method of claim 8, wherein creating the corresponding bridged routing entry 
for the main routing entry comprises: 

creating a bridged routing vector for the bridged routing entry. 
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10. The method of claim 8, wherein creating the corresponding bridged routing entry 
for the main routing entry comprises: 

including in the bridged routing entry a reference to the main routing entry in the 
main routing table. 

5 

1 1 . The method of claim 6, wherein determining that the bridge is needed between the 
first communication interface and the second communication interface comprises: 

detecting a failure affecting communication over the first communication interface. 

10 12. The method of claim 6, wherein the plurality of communication interfaces 

comprises a plurality of Hne cards. 
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13. A method for protection switching in a networking device having a plurality of 
communication interfaces, the method comprising: 

pre-establishing a bridged routing table for each of a number of communication 
interface pairs, where each communication interface pair represents a working 
5 communication interface and a corresponding protection communication interface from 

among the plurality of communication interfaces; 

detecting a failure affecting communication over a working communication 
interface; 

determining a protection communication interface to protect the working 
10 communication interface; 

obtaining the pre-established bridged routing table for the communication interface 
pair associated with the working communication interface and the protection 
communication interface; and 

bridging the protection communication interface to the working communication 
15 interface using the pre-established bridged routing table for the communication interface 

pair associated with the working communication interface and the protection 
communication interface. 

14. The method of claim 13, wherein pre-establishing a bridged routing table for a 
20 communication interface pair comprises: 

finding in a main routing table a number of main routing entries having the 
working communication interface as an outgoing interface; and 

creating in the bridged routing table a corresponding bridged routing entry for each 
of said number of main routing entries, wherein each bridged routing entry includes all 
25 outgoing interfaces from its corresponding main routing entry and further includes the 

protection communication interface as an outgoing interface. 

15. The method of claim 14, wherein creating a corresponding bridged routing entry 
for a main routing entry comprises: 
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copying the main routing entry as a bridged routing entry into the bridged routing 
table; and 

adding the protection communication interface as an outgoing interface to the 
bridged routing entry. 

5 

16. The method of claim 15, wherein creating the corresponding bridged routing entry 
for the main routing entry comprises: 

creating a bridged routing vector for the bridged routing entry. 

10 17. The method of claim 15, wherein creating the corresponding bridged routing entry 

for the main routing entry comprises: 

including in the bridged routing entry a reference to the main routing entry in the 
main routing table. 



1 8. The method of claim 13, wherein the plurality of communication interfaces 
comprises a plurality of line cards. 
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19. An apparatus comprising: 

a plurality of communication interfaces; 

bridge pre-establishment logic operably coupled to create a bridged routing entry 
for bridging a first communication interface and a second interface from among the 
plurality of communication interfaces before a bridge is needed between the first 
communication interface and the second interface; and 

bridge establishment logic operably coupled to establish a bridge between the first 
communication interface and the second communication interface using the pre- 
estabhshed bridged routing entry upon determining that a bridge is needed between the 
first communication interface and the second communication interface. 

20. The apparatus of claim 19, wherein the bridge pre-establishment logic is operably 
coupled to create the bridged routing entry by adding the second communication interface 
as an outgoing interface to a routing entry having the first communication interface as an 
outgoing interface. 

21 . The apparatus of claim 20, wherein the bridge pre-establishment logic is operably 
coupled to create a bridged routing vector for bridging the first communication interface 
and the second communication interface. 

22. The apparatus of claim 19, wherein the bridge establishment logic is operably 
coupled to establish the bridge upon detecting a failure affecting communication over the 
first communication interface. 

23. The apparatus of claim 19, wherein the plurality of communication interfaces 
comprises a plurality of line cards. 
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24. A computer program for controlling a computer system, the computer program 
comprising: 

bridge pre-establishment logic programmed to create a bridged routing entry for 
bridging a first communication interface and a second interface from among a plurality of 
communication interfaces before a bridge is needed between the first communication 
interface and the second interface; and 

bridge establishment logic programmed to establish a bridge between the first 
communication interface and the second communication interface using the pre- 
established bridged routing entry upon determining that a bridge is needed between the 
first communication interface and the second communication interface. 

25. The computer program of claim 24, wherein the bridge pre-establishment logic is 
programmed to create the bridged routing entry by adding the second communication 
interface as an outgoing interface to a routing entry having the first communication 
interface as an outgoing interface. 

26. The computer program of claim 25, wherein the bridge pre-establishment logic is 
programmed to create a bridged routing vector for bridging the first communication 
interface and the second communication interface. 

27. The computer program of claim 24, wherein the bridge establishment logic is 
programmed to establish the bridge upon detecting a failure affecting communication over 
the first communication interface. 

28. The computer program of claim 24 embodied in a computer readable medium. 

29. The computer program of claim 24 embodied in a data signal. 
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30. An apparatus comprising: 

a plurality of communication interfaces; 

bridge pre-establishment logic operably coupled to create a bridged routing table 
for bridging a first communication interface and a second interface from among a plurality 
5 of communication interfaces before a bridge is needed between the first communication 

interface and the second interface; and 

bridge establishment logic operably coupled to establish a bridge between the first 
communication interface and the second communication interface using the pre- 
established bridged routing table upon determining that a bridge is needed between the 
10 first communication interface and the second communication interface. 

3 1 . The apparatus of claim 30, wherein the bridge pre-establishment logic is operably 
coupled to create the bridged routing table by finding in a main routing table a number of 
main routing entries having the first communication interface as an outgoing interface and 

15 creating in the bridged routing table a corresponding bridged routing entry for each of said 

number of main routing entries, wherein each bridged routing entry includes all outgoing 
interfaces from its corresponding main routing entry and further includes the second 
communication interface as an outgoing interface. 

20 32. The apparatus of claim 31, wherein the bridge pre-establishment logic is operably 

coupled to create a corresponding bridged routing entry for a main routing entry by 
copying the main routing entry as a bridged routing entry into the bridged routing table and 
adding the second communication interface as an outgoing interface to the bridged routing 
entry. 



33. The apparatus of claim 32, wherein the bridge pre-establishment logic is operably 
coupled to create a bridged routing vector for the bridged routing entry. 
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34. The apparatus of claim 32, wherein the bridge pre-establishment logic is operably 
coupled to include in the bridged routing entry a reference to the main routing entry in the 
main routing table. 

5 35. The apparatus of claim 30, wherein the bridge establishment logic is operably 

coupled to establish the bridge upon detecting a failure affecting communication over the 
first communication interface. 



36. The apparatus of claim 30, wherein the plurality of communication interfaces 
10 comprises a plurality of line cards. 
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37. A computer program for controlling a computer system, the computer program 
comprising: 

bridge pre-establishment logic programmed to create a bridged routing table for 
bridging a first communication interface and a second interface from among a plurality of 
5 communication interfaces before a bridge is needed between the first communication 

interface and the second interface; and 

bridge establishment logic programmed to establish a bridge between the first 
communication interface and the second communication interface using the pre- 
established bridged routing table upon determining that a bridge is needed between the 
10 first conununication interface and the second communication interface. 



38. The computer program of claim 37, wherein the bridge pre-establishment logic is 
programmed to create the bridged routing table by finding in a main routing table a 
number of main routing entries having the first communication interface as an outgoing 
15 interface and creating in the bridged routing table a corresponding bridged routing entry 

for each of said number of main routing entries, wherein each bridged routing entry 
includes all outgoing interfaces from its corresponding main routing entry and further 
includes the second communication interface as an outgoing interface. 



20 39. The computer program of claim 38, wherein the bridge pre-establishment logic is 

programmed to create a corresponding bridged routing entry for a main routing entry by 
copying the main routing entry as a bridged routing entry into the bridged routing table and 
adding the second communication interface as an outgoing interface to the bridged routing 
entry. 

25 

40. The computer program of claim 39, wherein the bridge pre-establishment logic is 
programmed to create a bridged routing vector for the bridged routing entry. 
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41 . The computer program of claim 39, wherein the bridge pre-establishment logic is 
programmed to include in the bridged routing entry a reference to the main routing entry in 
the main routing table. 

42. The computer program of claim 37, wherein the bridge establishment logic is 
progranmied to establish the bridge upon detecting a failure affecting communication over 
the first communication interface. 

43. The computer program of claim 37 embodied in a computer readable medium. 

44. The computer program of claim 37 embodied in a data signal. 
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45. An apparatus comprising: 

a plurality of communication interfaces; 

bridge pre-establishment logic operably coupled to create a bridged routing table 
for each of a number of communication interface pairs, where each communication 
interface pair represents a working communication interface and a corresponding 
protection communication interface from among the plurality of communication 
interfaces; and 

bridge establishment logic operably coupled to establish a bridge between a 
working communication interface and a corresponding protection communication interface 
using the bridged routing table associated with the working communication interface and 
corresponding protection communication interface upon detecting a failure affecting 
communication over the working communication interface. 

46. The apparatus of claim 45, wherein the bridge pre-establishment logic is operably 
coupled to create a bridged routing table for a communication interface pair by finding in a 
main routing table a number of main routing entries having the working communication 
interface as an outgoing interface and creating in the bridged routing table a corresponding 
bridged routing entry for each of said number of main routing entries, wherein each 
bridged routing entry includes all outgoing interfaces from its corresponding main routing 
entry and further includes the protection communication interface as an outgoing interface. 

47. The apparatus of claim 46, wherein the bridge pre-establishment logic is operably 
coupled to create a corresponding bridged routing entry for a main routing entry by 
copying the main routing entry as a bridged routing entry into the bridged routing table and 
adding the protection communication interface as an outgoing interface to the bridged 
routing entry. 

48. The apparatus of claim 47, wherein the bridge pre-establishment logic is operably 
coupled to create a bridged routing vector for the bridged routing entry. 
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49. The apparatus of claim 47, wherein the bridge pre-establishment logic is operably 
coupled to include in the bridged routing entry a reference to the main routing entry in the 
main routing table. 

50. The apparatus of claim 45, wherein the plurality of communication interfaces 
comprises a plurality of line cards. 
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51. A computer program for controlling a computer system, the computer program 
comprising: 

bridge pre-establishment logic programmed to create a bridged routing table for 
each of a number of communication interface pairs, where each communication interface 
pair represents a working communication interface and a corresponding protection 
communication interface from among the plurality of communication interfaces; and 

bridge establishment logic programmed to establish a bridge between a working 
communication interface and a corresponding protection communication interface using 
the bridged routing table associated with the working communication interface and 
corresponding protection communication interface upon detecting a failure affecting 
communication over the working communication interface. 

52. The computer program of claim 51, wherein the bridge pre-establishment logic is 
programmed to create a bridged routing table for a communication interface pair by 
finding in a main routing table a number of main routing entries having the working 
communication interface as an outgoing interface and creating in the bridged routing table 
a corresponding bridged routing entry for each of said number of main routing entries, 
wherein each bridged routing entry includes all outgoing interfaces from its corresponding 
main routing entry and further includes the protection communication interface as an 
outgoing interface. 

53. The computer program of claim 52, wherein the bridge pre-establishment logic is 
programmed to create a corresponding bridged routing entry for a main routing entry by 
copying the main routing entry as a bridged routing entry into the bridged routing table and 
adding the protection communication interface as an outgoing interface to the bridged 
routing entry. 

54. The computer program of claim 53, wherein the bridge pre-establishment logic is 
programmed to create a bridged routing vector for the bridged routing entry. 
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55. The computer program of claim 53, wherein the bridge pre-estabMshment logic is 
programmed to include in the bridged routing entry a reference to the main routing entry in 
the main routing table. 

56. The computer program of claim 5 1 embodied in a computer readable medium. 

57. The computer program of claim 51 embodied in a data signal. 
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ABSTRACT OF THE DISCLOSURE 



A system, device, and method for bridging network traffic between a first 
communication interface and a second communication interface uses a pre-computed 
bridged routing table to enable a bridge to be established quickly. The pre-computed 
bridged routing table includes the second communication interface as an outgoing 
interface in each routing table entry having the first communication interface as an 
outgoing interface. The bridged routing table is pre-computed for the pair of 
communication interfaces by searching a main routing table for all main routing table 
entries having the first communication interface as an outgoing interface and creating, for 
each such main routing table entry, a corresponding bridged routing table entry including 
all outgoing interfaces from the main routing table entry and additionally including the 
second (bridged) communication interface as an outgoing interface. Bridged routing tables 
may be pre-computed for multiple potential communication interface pairs. 
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FIG. 4A - Main Routing Table 
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FIG. 4B - Main Routing Vector 
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HG. 5A - Bridged Routing Table [Slotl,Slot2] 
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FIG. 5B - Bridged Routing Vector [Slotl,Slot2] 'C-^— 
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FIG. 6A - Bridged Routing Table [Slot5,Slot6] 
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FIG. 6B - Bridged Routing Vector [Slot5,Slot6] 




HG. 7A - Bridged Routing Table [Slot7,Slot8] 
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FIG. 7B - Bridged Routing Vector [Slot7,Slot8] 



(S1,G1) 



^ 1, 5,7,9, A,B,C "^{O 



(S2,G2) 



-5- 5,7,9,A 



2V> 




FIG. 8A - Bridged Routing Table [Slot9,SlotA] 
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FIG. 8B - Bridged Routing Vector [Slot9,SlotA] 
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FIG. 9A - Bridged Routing Table [Slotl,SlotE] 



SLE 


SLD 


SLC 


SLB 


SLA 


SL9 1 SL8 


SL7 


SL6 


SL5 


SL4 


SL3 


SL2 


SLl 


■ 1 






M 


II 






i 












1 


III 


III 


III 
















ii 



FIG. 9B - Bridged Routing Vector [Slotl.SlotE] 
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FIG. lOA - Bridged Routing Table [Slot5,SlotE] 
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FIG. lOB - Bridged Routing Vector [Slot5,SlotE] ^.^^ 
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FIG. 1 1 A - Bridged Routing Table [Slot7,SlotE] 
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FIG. 1 IB - Bridged Routing Vector [Slot7,SlotE] ' 
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FIG. 12A - Bridged Routing Table [Slot9,SlotE] 
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HG. 12B - Bridged Routing Vector [Slot9,SlotE] 
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1 Pre-compute bridged routing table entries for a predetermined pair of line cards 



Store the pre-computed bridged routing table entries 



tries I 







Subsequently use the pre-computed bridged routing table entries to 
establish a bridge between the predetermined pair of line cards 
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Obtain a routing table entry from the main routing table 



Determine whether the routing table entry 
includes the WLC as an outgoing interface 




not 
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Copy the routing table entry as a bridged routing table entry 
into the bridged routing table for the WLC/PLC pair 



Add the PLC as an outgoing interface of the bridged routing table entry 



Create a bridged routing vector identifying the slot ports for the PLC / 
(corresponding to the slots ports for the WLC) I 
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1 using the pre-computed bridged routing table 
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